package com.cg.offer;

import org.junit.Test;

/**
 * 剑指Offer 58-II.左旋转字符串
 *
 * @program: LeetCode->Offer_58_II
 * @description: 剑指Offer 58-II.左旋转字符串
 * @author: cg
 * @create: 2022-03-11 15:34
 **/
public class Offer_58_II {

    @Test
    public void test58() {
        System.out.println(reverseLeftWords("abcdefg", 2));
        System.out.println(reverseLeftWords("lrloseumgh", 6));
    }

    /**
     * 字符串的左旋转操作是把字符串前面的若干个字符转移到字符串的尾部。请定义一个函数实现字符串左旋转操作的功能。比如，输入字符串"abcdefg"和数字2，该函数将返回左旋转两位得到的结果"cdefgab"。
     * <p>
     * 示例 1：
     * 输入: s = "abcdefg", k = 2
     * 输出: "cdefgab"
     * <p>
     * 示例 2：
     * 输入: s = "lrloseumgh", k = 6
     * 输出: "umghlrlose"
     * <p>
     * 限制：
     * 1 <= k < s.length <= 10000
     *
     * @param s
     * @param n
     * @return
     */
    public String reverseLeftWords(String s, int n) {
        if (n >= s.length()) {
            return s;
        }
        StringBuilder res = new StringBuilder();
        char[] chars = s.toCharArray();
        for (int i = n; i < chars.length; i++) {
            res.append(chars[i]);
        }
        for (int i = 0; i < n; i++) {
            res.append(chars[i]);
        }
        return res.toString();
    }

}
